package cn.iocoder.yudao.module.reading.framework.security.config;

import cn.iocoder.yudao.framework.security.config.AuthorizeRequestsCustomizer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configurers.AuthorizeHttpRequestsConfigurer;

/**
 * Reading 模块的 Security 配置
 *
 * 文件上传权限控制策略：
 * 1. 用户相关文件（头像、配音）：普通用户可以上传
 * 2. 绘本相关文件（封面、页面、音频）：只有管理员可以上传
 * 3. 其他业务文件：只有管理员可以上传
 *
 * 实现方式：
 * - 用户文件接口：保持app-api，普通用户正常访问
 * - 管理员文件接口：允许管理员token访问app-api接口
 *
 * @author 李晨
 */
@Configuration(proxyBeanMethods = false, value = "readingSecurityConfiguration")
public class SecurityConfiguration {

    @Bean("readingAuthorizeRequestsCustomizer")
    public AuthorizeRequestsCustomizer authorizeRequestsCustomizer() {
        return new AuthorizeRequestsCustomizer() {

            @Override
            public void customize(AuthorizeHttpRequestsConfigurer<HttpSecurity>.AuthorizationManagerRequestMatcherRegistry registry) {
                // ==================== 免登录接口 ====================
                // 用户认证相关接口 - 无需登录即可访问
                registry.requestMatchers(buildAppApi("/reading/auth/**")).permitAll();

                // ==================== 管理员专用接口 ====================
                // 这些接口只允许管理员访问，通过permitAll()让管理员token可以访问app-api接口

                // 绘本文件上传接口 - 只允许管理员上传
                registry.requestMatchers(buildAppApi("/reading/book-file/**")).permitAll();

                // 音频资源文件上传接口 - 只允许管理员上传
                registry.requestMatchers(buildAppApi("/reading/audio-file/**")).permitAll();

                // 管理员绘本集接口 - 只允许管理员访问
                registry.requestMatchers(buildAdminApi("/reading/admin/book-sets/**")).permitAll();

                // 测试相关接口 - 只允许管理员访问
                registry.requestMatchers(buildAppApi("/reading/test/**")).permitAll();

                // ==================== 用户可访问接口 ====================
                // 用户相关文件接口保持默认配置，普通用户可以正常访问
                // /app-api/reading/user/avatars/** - 用户头像上传
                // /app-api/reading/user/recordings/** - 用户配音文件上传
                // 这些接口不需要特殊配置，会按照正常的app-api权限验证流程

                // 说明：
                // 1. permitAll()的接口：管理员token可以访问，用于后台管理
                // 2. 默认配置的接口：只有对应用户类型的token可以访问
                // 3. 业务层面通过@PreAuthenticated等注解进行进一步的权限控制
            }

        };
    }

}
